package com.tfswx.fljdmxyy.dao;

import com.tfswx.fljdmxyy.model.SjglYxYwst;
import com.tfswx.fljdmxyy.query.sjgl.StxxQueryResult;
import com.tfswx.fljdmxyy.query.sjgl.YwstQueryParam;
import com.tfswx.fljdmxyy.query.sjgl.YwzdgxQueryResult;
import org.apache.ibatis.annotations.MapKey;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

/**
 * 业务实体
 *
 * @Author 陈文佳
 * @Date 2023/03/24
 */
@Mapper
public interface SjglYxYwstMapper {
    /**
     * 新增业务实体
     *
     * @param param 新增业务实体入参
     * @return Integer 影响条数
     */
    Integer insertSjglYxYwst(SjglYxYwst param);

    /**
     * 删除业务实体
     *
     * @param param 删除业务实体入参
     * @return Integer 影响条数
     */
    Integer deleteSjglYxYwst(SjglYxYwst param);

    /**
     * 修改业务实体
     *
     * @param param 修改业务实体入参
     * @return Integer 影响条数
     */
    Integer updateSjglYxYwst(SjglYxYwst param);

    /**
     * 查询业务实体
     *
     * @param param 查询业务实体入参
     * @return SjglYxYwst 业务实体
     */
    SjglYxYwst getSjglYxYwst(SjglYxYwst param);

    /**
     * 查询业务实体列表
     *
     * @param param 查询业务实体列表入参
     * @return List<SjglYxYwst> 业务实体列表
     */
    List<SjglYxYwst> querySjglYxYwst(YwstQueryParam param);

    /**
     * 执行sql
     *
     * @param sql 执行sql入参
     * @return List<Map<String, Object>> 执行sql出参
     */
    @MapKey("id")
    List<Map<String, Object>> queryData(@Param("sql") String sql);

    /**
     * 查询表单字段关系
     *
     * @return List<YwzdgxQueryResult> 查询表单字段关系出参
     */
    List<YwzdgxQueryResult> queryYwzdgx();

    /**
     * 查询实体信息
     *
     * @return List<StxxQueryResult> 查询实体信息出参
     */
    List<StxxQueryResult> queryStxx();
}
